
' I (NewJ A system tor pertorming address translations in a processor employing both 

segmentation and optional independent paging the system comprising: 

a page cache providing an actual physical page frame address from a virtual address in a 
time period T, the page frame cache accessed by using a page field of a fully calculated linear 
address; and 

^J^y^ ^ speculative physical page frame address generator providing a speculative physical page 

address related to said virtual address in a time < T; 

wherein the respective page frames are combined with offset portions to produce physical 
memory addresses. 

/ 

(New) The system of claim^^^ wherein the speculative physical page frame address can be 
used for generating a memory access faster than a memory access based on said actual 
physical page frame address^ 

(New) The system of clairn^ wherein the memory access is to a cache memory. 
^ yi, (New) The system of claini^ including a cancellation circuit for canceling the memory 

access if the speculative physical page frame address and actual physical page frame address 
are different. 

^ (New) The system of claim 38, wherein the specialative physical page frame address 

generator comprises a second page frame cache. 

(New) The system of claim ^wherein the speculative physical page frame address generator 
comprises a page frame address cache accessed during calculation of said fully calculated 
linear address. 
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^ (New) A circuit for performing memory accesses in a microprocessor system that uses a virtual 
address having a segment identifier and a segment offset, the circuit comprising: 

a) a linear address generator adapted to calculate a calculated linear address based on 
processing the entire virtual address; and 

b) a physical address generator, coupled to the linear address generator, adapted to generate a 
calculated physical address based on processing all of said calculated linear address, said 
physical address generator including a first memory for caching said calculated physical 
address; and 

c) a second memory coupled to the linear address generator storing physical address 
information usable to generate a tentative physical address; 

wherein said tentative physical address is used to initiate a tentative memory access that is 
completed unless said tentative physical address is different from said calculated physical 
address, in which case said calculated physical address is instead used for a calculated memory 
access. 

(New) The circuit of claim wherein said tentative physical address and said calculated 
physical address are generated in parallel, and said tentative physical address is completed before 
said calculated physical address can be completed by said physical address generator. 
^ (New) The circuit of claim ^ wherein said tentative physical address is generated based on 

processing a portion of said calculated linear address. 

If 7 

(New) The circuit of claim ^4, wherein said physical address information in said second memory 

is derived from a translation of a prior virtual address. 

(New) The circuit of claim ^wherein said first memory is a page cache located in a paging unit 
of the microprocessor. 

(New) The circuit of claim wherein said second memory includes segment descriptor 

information. _ 
50, (New) The circuit of claim 46, wherein said calculated linear address is a 32 bit linear address, 

and said tentative physical address is based on a lower portion of said 32 bit linear address. 
^. (New) The circuit of claim wherein the tentative memory access and calculated memory 

access are to a cache memory. 
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(New) A computer system using segmentation and optional independent paging for performing 
address translations comprising: 

an address translation memory capable of storing a portion of a physical address 
corresponding to a stored page frame; 

a virtual to linear address converter circuit for generating a calculated linear address; 

and 

a linear to physical address converter circuit for receiving and generating a calculated 
physical address based on the calculated linear address, the calculated physical address 
including a first page frame and a first page offset; and 

a fast physical address circuit generating a fast physical address comprised of the stored 
page frame combined with a page offset portion derived from the virtual address; 

wherein the fast physical address is generated prior to the generation of said calculated 
physical address, 

56. (New) The system of claim wherein the fast physical address can be used to initiate a fast 
memory access sooner than a memory access resulting from said first physical address. 
(New) The system of claim 5^, including a cancellation circuit for canceling the fast memory 
access if the fast physical address and first physical address are different. 
/ ^ (New) The circuit of claim ^'wherein the fast physical address is generated during the 
generation of the first linear address. 

(New) The system of claim wherein the stored page frame is generated in a prior address 
translation based on a prior virtual address. 
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57. (Hew) Ajpethod of generating a speculative memory address from a virtual address having both 
a segment iaCTitifier and a segment offset in a computer system employing both segmentation 
and optional indepeh(^nt paging, the^^rrgthod including the steps of: 

(a) converting a portiotsQf^the virtual address J/mp a partial linear address; and 

(b) combining the partm linear^ad^ress witi/ physical address information obtained from a 
prior memory addres/ generation to gen^ate-do^peculative memory address. 

58. (New) The method of ckim 57, \s4ferein the speculative memory addressTS^^is^ to initiate a 
speculative memory access. 

59. (New) The method of claim 58 wherein the speculative memory access is to a cache mer 



^ (New) A method of performing memory references in a processor that employs both 

segmentation and optional independent paging during an address translation, said system 
comprising: 

performing an actual address translation from a virtual address by first calculating a linear 
address based on both a segment identifier and an offset associated with the virtual address, 
and then generating an actual physical address based on the calculated linear address; and 

performing a speculative address translation from the virtual address using portions of the 
linear address and actual physical address information from a prior virtual address translation 
to produce a speculative physical address; 

performing a memory reference using the speculative physical address; 
validating that the memory reference is valid. 

m. (New) The method of claim ^ wherein the validating step comprises comparing the page frame 
portions of the actual physical address and the speculative physical address. 
^ 62. (New) The method of claim 6l, further including a step of canceling the memory reference if 
the page frame portions of the actual physical address and the speculative physical address are 
different. 
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(New) A method of performing memory accesses in a microprocessor system using a virtual 
address having a segment identifier and a segment offset, the method comprising the steps of: 

(a) generating a calculated linear address based on processing said entire virtual address; 

(b) using a first cache containing physical address information to generate a calculated physical 
address based on said calculated linear address; 

(c) using a second cache containing physical address information to generate a tentative physical 
address in parallel with step (a) and before step (b) is completed, said tentative physical 
address being based in part on a portion of said calculated linear address; 

(d) using said tentative physical address to initiate a tentative memory access to a cache; 

(e) completing said tentative memory access to said cache when said tentative physical address 
and said calculated physical address are the same; 

(f) aborting said tentative memory access and performing a second memory access based on 
said calculated physical address when said tentative physical address and said calculated 

J physical address are different. 

64. (New) The method of claim 66, wherein said first cache is a page cache located in a paging umt 

^ of the microprocessor. 

(New) The method of claim ^ wherein said second cache includes segment descriptor 
^ information. ^5 

(New) The method of claim ^^(^ wherein said calculated linear address is a 32 bit linear address, 
and said tentative physical address is based on a lower portion of said 32 bit linear address. 



